草庐IT

C++ CUDA 指向成员的指针

全部标签

c++ - ctypes 类成员访问段错误

我有兴趣在Python中使用C++类。看着CallingC/C++frompython?,我决定尝试ctypes。但是,当我尝试更改类成员的值时出现段错误。这是一个重现我的问题的简单示例:C/C++方面:#includeclassFoo{private:intmValue;public:voidbar(){std::coutbar();}voidFoo_setValue(Foo*foo,intv){foo->setValue(v);}voidFoo_setValue2(Foo*foo){foo->setValue2();}}代码在OSX上编译:g++-c-fPICfoo.cpp-ofo

c++ - 特殊成员函数是 noexcept 还是 throw()?

C++11规范明确指出隐式生成的特殊函数(即默认构造函数、析构函数、复制/移动构造函数和复制/移动赋值运算符)具有异常规范。但该规范似乎仅根据现已弃用的动态异常规范(即“throw(T1,T2,T3)”)编写。15.4/14中的示例支持这一点:structA{A();A(constA&)throw();A(A&&)throw();~A()throw(X);};structB{B()throw();B(constB&)throw();B(B&&)throw(Y);~B()throw(Y);};structD:publicA,publicB{//ImplicitdeclarationofD

当 C++ 使用智能指针时,C# 委托(delegate)等效

我主要是一名从事C++项目的.NET程序员,我正在尝试确定处理使用Action和Function模板类型的委托(delegate)的等效方法。我将委托(delegate)用作.NET代码中的事件和回调。我的C++项目使用智能指针和与C#程序相同的委托(delegate)设计模式。处理这种情况的最佳方法是什么?我不清楚如何传递和维护一个函数指针,该函数指针还跟踪智能指针并可能删除底层对象,因为事件容器使用弱引用。该库需要是多平台的,因此不幸的是,使用CLR不是一种选择。 最佳答案 您正在寻找的是绑定(bind)到现有对象的方法指针,就

c++ - 小于函数解引用指针

在某些情况下,STL容器中有指针,小于比较不应由指针进行,而应由指向的对象进行。一个简单的例子是一个vector,它应该按实数排序。目前我解决这个问题:templatestructltDeref{booloperator()(T_PTRp0,T_PTRp1)const{return*p0并将其用作vectorvIn;sort(vIn.begin(),vIn.end(),ltDeref());或set>someSet;与其编写我自己的比较函数,不如在C++中有更“标准”的方法,它不需要用户制作的模板? 最佳答案 通常你可以使用thef

c++ - 我有两个 GPU,我怎么能只让其中一个执行特定的 CUDA 任务呢?

刚接触CUDA,但有一些时间花在计算上,我家里有geforces,办公室有tesla(同代)。在家里,我在同一台计算机上安装了两个gpus,一个是GK110(计算能力3.5),另一个是GF110(计算能力2.0),我更喜欢使用GK110仅用于计算任务,GF110用于显示,除非我告诉它进行计算,有没有办法通过驱动程序设置来完成,或者我仍然需要重写我的一些代码?另外,如果我没理解错的话,如果GK110的显示端口没有连接,那么烦人的windows超时检测即使计算时间很长也不会尝试重置它?顺便说一句,我的CUDA代码是用compute_35和compute20编译的,因此代码可以在两个GPU上

c++ - 通用成员函数指针作为另一个类中的模板参数

我的问题类似于this.而'KarrekSB'sanswer实际上对我有所帮助。我有这些类(class):基础.h:classBase{public:Base(){}virtual~Base(){}virtualvoidinit()=0;};A1.h:#include#include"Base.h"usingnamespacestd;classA1:publicBase{public:A1(){}virtual~A1(){};virtualvoidinit(){cout我有另一个类应该能够存储具有任何类型和数量的参数的任何通用成员函数。该类看起来像这样:MFholder.h:#incl

c++ - 通过指针获取: good practice?装饰一个char*和char const*

你好,我想就我做一个字符串类(如std::string)的想法向公众进行投票,该字符串类具有能够在客户端提供的缓冲区上工作的特性。您预见到的危险是什么?是经典的味道吗?等等我的意思是:charext[64]={0};my::strings(ext,my::string::acquire_RW);size_tlen=s.size();size_tpos=s.find("zboub");my::strings2(s);//usestrue(alloc+)copysemantichere.所以我预见了2种策略:acquire_RW和acquire_RO将允许或不允许修改ext中的字符。在RO

c++ - 将 MPI 与 c++11 和 CUDA 相结合

我正在编写分子动力学模拟,一些内核将使用CUDA进行计算。我从使用一些c++11功能的普通CPU实现开始我的代码。现在我必须添加一些CUDA代码,我必须使用不支持c++11功能的编译器(gcc在我的makefile中,我分别从所有cpp文件创建对象,最后将它们全部链接在一起。此外,我的代码以这样一种方式拆分,即可以使用“现代”编译器编译没有CUDA的部分,而使用旧编译器编译其余部分(利用CUDA)。我现在的问题是,这是否可以,或者我是否会/可能会遇到问题? 最佳答案 我不知道Cuda,但我知道的是将C++98和C++11目标文件链接

c++ - 改进 CUDA 中的异步执行

我目前正在编写一个程序,使用CUDAAPI在GPU上执行大型模拟。为了加速性能,我尝试同时运行我的内核,然后再次将结果异步复制到主机内存中。代码大致如下所示:#defineNSTREAMS8#defineBLOCKDIMX16#defineBLOCKDIMY16voiddomainUpdate(float*domain_cpu,//pointertodomainonhostfloat*domain_gpu,//pointertodomainondeviceconstunsignedintdimX,constunsignedintdimY,constunsignedintdimZ){di

c++ - 当同名类模板存在时,需要范围解析运算符调用成员函数模板

我有一个类模板恰好与某些类的成员函数模板同名。现在另一个函数模板被实例化为其中一个具有相关成员函数模板的类。要在此函数模板中调用成员函数模板,我需要使用template关键字,我理解这一点并且对此没有问题。但是,我需要使用范围解析运算符(我刚刚发现这就是所谓的)::指定我的意思是类的成员函数模板而不是类模板,我不明白为什么。这是很多模板化的东西,所以让我举个例子://classwithsamenameasmemberfunctionbelow.//mustbeclasstemplateorerrordoesn'tshowup.//alsonoerrorifthisisafunction